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PURPOSE OF DECLARATION 

1. This declaration is to establish completion of the invention of this application in The 
United States at a date prior to the effective date of the prior art publications, Federwisch et al., 
U.S. Publication No. 2003/01 823 13 published September 25, 2003, and Edwards, U.S. 
Publication No. 2003/0182389 published September 25, 2003, both of which were cited by the 
Examiner. 

2. The person making this declaration is Vijayan Rajan, a joint inventor. 

FACTS AND DOCUMENTARY EVIDENCE 

3. To establish the date of completion of the invention of this application, the following 
attached document is submitted as evidence: 

"Lazy Lun Cloning Specification". 

4. Mr. Vijayan Rajan, a joint inventor, swears that the conception of the invention was 
prior to September 25, 2003, the effective dates of the references. 

DILIGENCE 

5. Mr. Vijayan Rajan acknowledges through this declaration that Applicant acted with 
diligence in the completion of the invention from the time of conception, to a time just prior to 
the date of the reference, up to the filing of this application. 

DECLARATION 

6. I, Vijayan Rajan, as a joint inventor of the present invention, hereby declare that all 
statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with 
the knowledge that willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code, and that such 
willful false statements may jeopardize the validity of the application or any patent issued 
thereon. 
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7. Full name of (joint/sole) inventor (please print): _ 
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USA 



U5A 



Post Office Address: ^ 5"D Tti-omP^DM /We 



Notarized by: H^'hcx. Km-vwu-nX fav^ U. 



Signature of Notary: _ 
My Commission Expires; e )uvie S^tl . 
.SEAL •' 




HEENA KUMARI PARIi 
1 Commission #1750834 
Notary Public -California 

Santa Clara r 
Comm. Expires 
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State of California 
County of Santa Clara 
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Introduction 



Lazy LUN cloning allows users to clone exiting LUCTs with zero-downtime LUNS 
backed by a snapshot have part of their data blocks in a snapshot and part of 
it in thi active file system. Thus as long as the LUN being used the 
backing snapshot cannot be deleted, which locks in the blocks from other files 
on the volume as well. 

It is desired that it should be possible to delete the snapshot after some 
reasonable period of time without loosing the contents of the LU* and without 
taking the LUH offline. 

The proposed LXJN cloning techinque allows this by cloning the contents of the 
X.UN in the background, thus "Lazy", without any application visible downtime. 
Once the cloning is complete the backing snapshot can then be deleted. 

Rote that SFSR is not a solution here since we wish to retain thecont ents of 
the LtJN as is and not restore to the version m the snapshot. Further for SF SR 
the LUN would be unavailable for the duration of the operation and thus not a 
solution to the problem at hand. 



Design Details 



in the initial cut of the implementation, the cloning will be done entirely 
using backdoor messages and no nvlog protection. 

It is not necessary to avoid the buffer copy when a level -0 buffer does not 
Sist.Jn the activl filesystem and thus forms the basis of our implementation. 

wafl load buf () on the active filesystem inode already fetches the correct 
contents,-from the most recent applicable snapshot file. This is true 
level-0 blocks. Fo'r levels greater than 0, the contents are those corresponding 
to the active filesystem only. 

vdisk backup compute level_one_buf () computes a level-1 buffer. (When writable 
snapshot files have holes, this loads all backing modes, and composes the 
result buffer. ) 

We compare the level-1 buffers from the inode in the active f i^^^em and f rom 
that in the snapshot and if there are any holes in the active filesystem we 
load the corressponding level-0 buffers and mark them dirty. 

If a buffer for the active filesystem inode is marked dirty, it is written back 
to the active filesystem inode, in the normal manner. 

The cloning process is complete when the backdoor message handler "turns 
successfully. At this poing the lock on the snapshot is released, the entry in 
the vtoc is updated to remove the snapshot reference and the user informed of 
the completion through a syslogged message. 
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The cloning is done entirely in the background without any NVLOG protection. 
If we panic in the middle of a cloning operation, the operation is restarted 
from the beginning on a reboot/ takeover (see Future below) . 



Implementation Details 



+ load writable snapshot vdisk's level-1 buffers using waf l_load_buf 
+ load corresponding level-1 buffers for backing snapshot file, with 

vdisk_backup_compute_level_one_buf {) , instead. 
+ where level -0 vbn for active filesystem inode is 0, and for the backing 

file is non-zero: 

- load the active filesystem inode level 0 buffer 

- wafl_set_buf_dirty{) on the buffer 

+ If a complete scan is performed, and no buffers were marked dirty, do a 

backdoor_send operation to update the vtoc entry 
+ Otherwise do wafl_sync() to write -the dirty buffers to disk and then update 

the vtoc entry- 



Other UI Details 



A new lun subcommand "lun clone" will be introduced with following sub options: 
+ "lun clone show [ <path> ] " will list all the luns being cloned 
+ "lun clone status <path>" will report the progress on the cloning operation 
+ "lun clone start <path>" will start of the cloning process 
+ "lun clone stop <path>" will stop the operation 



Future 



1. Make multiple clones of a single lun simultaneously 

2. Keep track of the amount of work done and avoid redoing all the work on a 
reboot . 



Test Plan 



TBD 



Tracking Burt 

burt 77100 RFE: Simple LOT cloning implementation 

(Most of the text in this specification is borrowed from Vijayan's Hotes in 
this burt. ) 



vinay@netapp . com 



